.container {
    position: absolute;
    top: 40%;
    left: 90%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 15px;
    height: 15px;
    cursor: pointer;
}
.dot {
    position: absolute;
    bottom: -2px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 6px;
    height: 6px;
    background: #b2ca16;
    border-radius: 50%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
.container.hover .dot {
    background: transparent;
    width: 0;
}
.dot::before,
.dot::after {
    display: block;
    content: '';
    position: absolute;
    bottom: 0;
    background: #b2ca16;
    width: 6px;
    height: 6px;
    border-radius: 50%;
}
.container.hover .dot::before,
.container.hover .dot::after {
    height: 15px;
    border-radius: 0;
    bottom: -3px;
}
.dot::before {
    left: -9px;
}
.container.hover .dot::before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transform-origin: right bottom;
    -ms-transform-origin: right bottom;
    transform-origin: right bottom;
    border-radius: 9px;
}
.dot::after {
    right: -9px;
}
.container.hover .dot::after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform-origin: left bottom;
    -ms-transform-origin: left bottom;
    transform-origin: left bottom;
    border-radius: 9px;
}